home *** CD-ROM | disk | FTP | other *** search
/ The Atari Compendium / The Atari Compendium (Toad Computers) (1994).iso / files / prgtools / mint / lib / mntc6846.zoo / mintbind.h < prev    next >
Encoding:
C/C++ Source or Header  |  1995-04-23  |  21.6 KB  |  616 lines

  1. #ifndef _MINTBIND_H
  2. #define _MINTBIND_H
  3.  
  4. #ifndef _OSBIND_H
  5. #include <osbind.h>
  6. #endif
  7.  
  8. #ifdef __cplusplus
  9. extern "C" {
  10. #endif
  11.  
  12. #ifdef __TURBOC__
  13.  
  14. /* we supply a library of bindings for TurboC / PureC */
  15.  
  16. int Syield( void );                /* GEMDOS 0xff */
  17. int Fpipe( short *ptr );            /* GEMDOS 0x100 */
  18. long Fcntl( int f, long arg, int cmd);        /* GEMDOS 0x104 */
  19. #define Fcntl(f, arg, cmd) Fcntl(f, (long)(arg), cmd)
  20. long Finstat( int f );                /* GEMDOS 0x105 */
  21. long Foutstat( int f );                /* GEMDOS 0x106 */
  22. long Fgetchar(int f, int mode);            /* GEMDOS 0x107 */
  23. long Fputchar( int f, long c, int mode );     /* GEMDOS 0x108 */
  24. long Pwait( void );                /* GEMDOS 0x109 */
  25. int Pnice( int delta );                /* GEMDOS 0x10a */
  26. int Pgetpid( void );                /* GEMDOS 0x10b */
  27. int Pgetppid( void );                /* GEMDOS 0x10c */
  28. int Pgetpgrp( void );                /* GEMDOS 0x10d */
  29. int Psetpgrp(int pid, int newgrp);        /* GEMDOS 0x10e */
  30. int Pgetuid( void );                /* GEMDOS 0x10f */
  31. int Psetuid( int id );                /* GEMDOS 0x110 */
  32. int Pkill( int pid, int sig );            /* GEMDOS 0x111 */
  33. long Psignal(int sig, long handler);        /* GEMDOS 0x112 */
  34. long Pvfork( void );                /* GEMDOS 0x113 */
  35. int Pgetgid( void );                /* GEMDOS 0x114 */
  36. int Psetgid(int id);                /* GEMDOS 0x115 */
  37. long Psigblock(unsigned long mask);        /* GEMDOS 0x116 */
  38. long Psigsetmask(unsigned long mask);        /* GEMDOS 0x117 */
  39. long Pusrval(long arg);                /* GEMDOS 0x118 */
  40. int Pdomain(int newdom);            /* GEMDOS 0x119 */
  41. void Psigreturn( void );            /* GEMDOS 0x11a */
  42. long Pfork( void );                /* GEMDOS 0x11b */
  43. long Pwait3(int flag, long *rusage);        /* GEMDOS 0x11c */
  44. int Fselect(unsigned int timeout, long *rfds, long *wfds, long *xfds); /* GEMDOS 0x11d */
  45. int Prusage( long r[8] );            /* GEMDOS 0x11e */
  46. long Psetlimit(int lim, long value);        /* GEMDOS 0x11f */
  47. long Talarm( long secs );            /* GEMDOS 0x120 */
  48. void Pause( void );                /* GEMDOS 0x121 */
  49. long Sysconf( int n );                /* GEMDOS 0x122 */
  50. long Psigpending( void );            /* GEMDOS 0x123 */
  51. long Dpathconf( const char *name, int n );    /* GEMDOS 0x124 */
  52. long Pmsg( int mode, long mbox, void *msg );     /* GEMDOS 0x125 */
  53. long Fmidipipe( int pid, int in, int out );    /* GEMDOS 0x126 */
  54. int Prenice( int pid, int delta );        /* GEMDOS 0x127 */
  55. long Dopendir( const char *name, int flag );    /* GEMDOS 0x128 */
  56. long Dreaddir( int buflen, long dir, char *buf); /*GEMDOS 0x129 */
  57. #define Dreaddir(buflen, dir, buf) Dreaddir(buflen, (long)(dir), buf)
  58. long Drewinddir( long dir );            /* GEMDOS 0x12a */
  59. #define Drewinddir(dir) Drewinddir((long)(dir))
  60. long Dclosedir( long dir );            /* GEMDOS 0x12b */
  61. #define Dclosedir(dir) Dclosedir((long)(dir))
  62. long Fxattr( int flag, char *name, void *buf );    /* GEMDOS 0x12c */
  63. long Flink( char *oldname, char *newname );    /* GEMDOS 0x12d */
  64. long Fsymlink( char *oldname, char *newname );    /* GEMDOS 0x12e */
  65. long Freadlink( int siz, char *buf, char *name); /*GEMDOS 0x12f */
  66. long Dcntl( int cmd, char *name, long arg );    /* GEMDOS 0x130 */
  67. long Fchown( char *name, int uid, int gid);    /* GEMDOS 0x131 */
  68. long Fchmod( char *name, int mode );        /* GEMDOS 0x132 */
  69. int Pumask( int mask );                /* GEMDOS 0x133 */
  70. long Psemaphore(int mode, long id, long timeout); /* GEMDOS 0x134 */
  71. int Dlock( int mode, int drive );        /* GEMDOS 0x135 */
  72. void Psigpause( unsigned long mask);        /* GEMDOS 0x136 */
  73. long Psigaction(int sig, long act, long oact);    /* GEMDOS 0x137 */
  74. #define Psigaction(sig, act, oact) \
  75.     Psigaction(sig, (long)(act), (long)(oact))
  76. int Pgeteuid( void );                /* GEMDOS 0x138 */
  77. int Pgetegid( void );                /* GEMDOS 0x139 */
  78. long Pwaitpid(int pid, int flag, long *rusage);    /* GEMDOS 0x13a */
  79. long Dgetcwd(char *path, int drv, int size);    /* GEMDOS 0x13b */
  80. long Salert(char *msg);                /* GEMDOS 0x13c */
  81.  
  82. #else /* !__TURBOC__ */
  83.  
  84. #ifdef __LATTICE__
  85.  
  86. void _vmv(int);
  87. short _smv(int);
  88. int _imv(int);
  89. long _lmv(int);
  90.  
  91. int _im8(int,long[8]);
  92. void _vml(int,long);
  93. short _sms(int,int);
  94. short _smr(int,short *);
  95. long _lms(int,int);
  96. long _lml(int,long);
  97. long _lmu(int,unsigned long);
  98. long _lmp(int,void *);
  99. long _lmC(int,const char *);
  100.  
  101. void _vmls(int,long,int);
  102. short _smss(int,int,int);
  103. short _smsl(int,int,long);
  104. short _smls(int,long,int);
  105.  
  106. long _lmss(int,int,int);
  107. long _lmsl(int,int,long);
  108. long _lmsp(int,int,void *);
  109. long _lmps(int,void *,int);
  110. long _lmCs(int,const char *,short);
  111. long _lmpp(int,void *,void *);
  112. long _lmCC(int,const char *,const char *);
  113.  
  114. short _smsls(int,int,long,int);
  115. int _imssq(int,int,int,long *);
  116. long _lmsss(int,int,int,int);
  117. long _lmsls(int,int,long,int);
  118. long _lmsll(int,int,int,long);
  119. long _lmslp(int,int,long,void *);
  120. long _lmspl(int,int,void *,long);
  121. long _lmsCl(int,int,const char *,long);
  122. long _lmspp(int,int,void *,void *);
  123. long _lmspC(int,int,void *,const char *);
  124. long _lmlss(int,long,int,int);
  125. long _lmCss(int,const char *,int,int);
  126. long _lmcss(int,char *,int,int);
  127. short _smsqqq(int,int,long *,long *,long *);
  128.  
  129. #pragma inline _vmv((short))    {register d2,a2; "4e41";}
  130. #pragma inline d0=_smv((short))    {register d2,a2; "4e41";}
  131. #pragma inline d0=_imv((short))    {register d2,a2; "4e41";}
  132. #pragma inline d0=_lmv((short))    {register d2,a2; "4e41";}
  133.  
  134. #pragma inline d0=_im8((short),)    {register d2,a2; "4e41";}
  135. #pragma inline _vml((short),)    {register d2,a2; "4e41";}
  136. #pragma inline d0=_sms((short),(short))    {register d2,a2; "4e41";}
  137. #pragma inline d0=_smr((short),)    {register d2,a2; "4e41";}
  138. #pragma inline d0=_lms((short),(short))    {register d2,a2; "4e41";}
  139. #pragma inline d0=_lml((short),)    {register d2,a2; "4e41";}
  140. #pragma inline d0=_lmu((short),)    {register d2,a2; "4e41";}
  141. #pragma inline d0=_lmp((short),)    {register d2,a2; "4e41";}
  142. #pragma inline d0=_lmC((short),)    {register d2,a2; "4e41";}
  143.  
  144. #pragma inline _vmls((short),,(short))    {register d2,a2; "4e41";}
  145. #pragma inline d0=_smss((short),(short),(short))    {register d2,a2; "4e41";}
  146. #pragma inline d0=_smsl((short),(short),)    {register d2,a2; "4e41";}
  147. #pragma inline d0=_smls((short),,(short))    {register d2,a2; "4e41";}
  148. #pragma inline d0=_lmss((short),(short),(short))    {register d2,a2; "4e41";}
  149. #pragma inline d0=_lmsl((short),(short),)    {register d2,a2; "4e41";}
  150. #pragma inline d0=_lmsp((short),(short),)    {register d2,a2; "4e41";}
  151. #pragma inline d0=_lmps((short),,(short))    {register d2,a2; "4e41";}
  152. #pragma inline d0=_lmCs((short),,(short))    {register d2,a2; "4e41";}
  153. #pragma inline d0=_lmpp((short),,)    {register d2,a2; "4e41";}
  154. #pragma inline d0=_lmCC((short),,)    {register d2,a2; "4e41";}
  155.  
  156. #pragma inline d0=_smsls((short),(short),,(short))    {register d2,a2; "4e41";}
  157. #pragma inline d0=_imssq((short),(short),(short),)    {register d2,a2; "4e41";}
  158. #pragma inline d0=_lmsss((short),(short),(short),(short))    {register d2,a2; "4e41";}
  159. #pragma inline d0=_lmsls((short),(short),,(short))    {register d2,a2; "4e41";}
  160. #pragma inline d0=_lmsll((short),(short),(short),)    {register d2,a2; "4e41";}
  161. #pragma inline d0=_lmlss((short),,(short),(short))    {register d2,a2; "4e41";}
  162. #pragma inline d0=_lmslp((short),(short),,)    {register d2,a2; "4e41";}
  163. #pragma inline d0=_lmspl((short),(short),,)    {register d2,a2; "4e41";}
  164. #pragma inline d0=_lmsCl((short),(short),,)    {register d2,a2; "4e41";}
  165. #pragma inline d0=_lmspp((short),(short),,)    {register d2,a2; "4e41";}
  166. #pragma inline d0=_lmspC((short),(short),,)    {register d2,a2; "4e41";}
  167. #pragma inline d0=_lmlss((short),,(short),(short))    {register d2,a2; "4e41";}
  168. #pragma inline d0=_lmCss((short),,(short),(short))    {register d2,a2; "4e41";}
  169. #pragma inline d0=_lmcss((short),,(short),(short))    {register d2,a2; "4e41";}
  170. #pragma inline d0=_smsqqq((short),(short),,,)    {register d2,a2; "4e41";}
  171.  
  172. #define Syield() _smv(0xff)
  173. #define Fpipe(a) _smr(0x100, a)
  174. #define Fcntl(a, b, c) _smsls(0x104, a, (long)b, c)
  175. #define Finstat(a) _lms(0x105, a)
  176. #define Foutstat(a) _lms(0x106, a)
  177. #define Fgetchar(a, b) _lmss(0x107, a, b)
  178. #define Fputchar(a, b, c) _lmsls(0x108, a, b, c)
  179. #define Pwait() _lmv(0x109)
  180. #define Pnice(a) _sms(0x10a, a)
  181. #define Pgetpid() _smv(0x10b)
  182. #define Pgetppid() _smv(0x10c)
  183. #define Pgetpgrp() _smv(0x10d)
  184. #define Psetpgrp(a, b) _smss(0x10e, a, b)
  185. #define Pgetuid() _smv(0x10f)
  186. #define Psetuid(a) _sms(0x110, a)
  187. #define Pkill(a, b) _smss(0x111, a, b)
  188. #define Psignal(a, b) _lmsl(0x112, a, b)
  189. #define Pvfork() _smv(0x113)
  190. #define Pgetgid() _smv(0x114)
  191. #define Psetgid(a) _sms(0x115, a)
  192. #define Psigblock(a) _lmu(0x116, a)
  193. #define Psigsetmask(a) _lmu(0x117, a)
  194. #define Pusrval(a) _lml(0x118, a)
  195. #define Pdomain(a) _sms(0x119, a)
  196. #define Psigreturn() _vmv(0x11a)
  197. #define Pfork() _lmv(0x11b)
  198. #define Pwait3(a, b) _lmsp(0x11c, a, b)
  199. #define Fselect(a, b, c, d) _smsqqq(0x11d, a, b, c, d)
  200. #define Prusage(a) _im8(0x11e, a)
  201. #define Psetlimit(a, b) _lmsl(0x11f, a, b)
  202. #define Talarm(a) _lml(0x120, a)
  203. #define Pause() _vmv(0x121)
  204. #define Sysconf(a) _lms(0x122, a)
  205. #define Psigpending() _lmv(0x123)
  206. #define Dpathconf(a, b) _lmCs(0x124, a, b)
  207. #define Pmsg(a, b, c) _lmslp(0x125, a, b, c)
  208. #define Fmidipipe(a, b, c) _lmsss(0x126, a, b, c)
  209. #define Prenice(a, b) _smss(0x127, a, b)
  210. #define Dopendir(a, b) _lmps(0x128, a, b)
  211. #define Dreaddir(a, b, c) _lmslp(0x129, a, b, c)
  212. #define Drewinddir(a) _lml(0x12a, a)
  213. #define Dclosedir(a) _lml(0x12b, a)
  214. #define Fxattr(a, b, c) _lmspp(0x12c, a, b, c)
  215. #define Flink(a, b) _lmCC(0x12d, a, b)
  216. #define Fsymlink(a, b) _lmCC(0x12e, a, b)
  217. #define Freadlink(a, b, c) _lmspC(0x12f, a, b, c)
  218. #define Dcntl(a, b, c) _lmsCl(0x130, a, b, (long)c)
  219. #define Fchown(a, b, c) _lmCss(0x131, a, b, c)
  220. #define Fchmod(a, b) _lmCs(0x132, a, b)
  221. #define Pumask(a) _sms(0x133, a)
  222. #define Psemaphore(a, b, c) _lmsll(0x134, a, b, c)
  223. #define Dlock(a, b) _smss(0x135, a, b)
  224. #define Psigpause(a) _vml(0x136,a)
  225. #define Psigaction(a, b, c) _lmsll(0x137, a, (long)b, (long)c)
  226. #define Pgeteuid() _imv(0x138)
  227. #define Pgetegid() _imv(0x139)
  228. #define Pwaitpid(a, b, c) _imssq(0x13a, a, b, c)
  229. #define Dgetcwd(a, b, c) _lmcss(0x13b, a, b, c)
  230. #define Salert(a) _lmC(0x13c, a)
  231.  
  232. #else /* !__LATTICE__ */
  233.  
  234. #ifdef __GNUC_INLINE__
  235.  
  236. /* see osbind.h for __extension__ and AND_MEMORY */
  237.  
  238. #define trap_1_wwlw(n, a, b, c)                        \
  239. __extension__                                \
  240. ({                                    \
  241.     register long retvalue __asm__("d0");                \
  242.     short _a = (short)(a);                        \
  243.     long  _b = (long) (b);                        \
  244.     short  _c = (short) (c);                    \
  245.                                         \
  246.     __asm__ volatile                        \
  247.     ("\
  248.         movw    %4,sp@-; \
  249.         movl    %3,sp@-; \
  250.         movw    %2,sp@-; \
  251.         movw    %1,sp@-; \
  252.         trap    #1;    \
  253.         lea    sp@(10),sp " \
  254.     : "=r"(retvalue)            /* outputs */        \
  255.     : "g"(n), "r"(_a), "r"(_b), "r"(_c)     /* inputs  */        \
  256.     : "d0", "d1", "d2", "a0", "a1", "a2"    /* clobbered regs */    \
  257.       AND_MEMORY                            \
  258.     );                                \
  259.     retvalue;                            \
  260. })
  261.  
  262. #define trap_1_wwww(n, a, b, c)                        \
  263. __extension__                                \
  264. ({                                    \
  265.     register long retvalue __asm__("d0");                \
  266.     short _a = (short)(a);                        \
  267.     short  _b = (short)(b);                        \
  268.     short  _c = (short)(c);                        \
  269.                                         \
  270.     __asm__ volatile                        \
  271.     ("\
  272.         movw    %4,sp@-; \
  273.         movw    %3,sp@-; \
  274.         movw    %2,sp@-; \
  275.         movw    %1,sp@-; \
  276.         trap    #1;    \
  277.         addqw    #8,sp "                    \
  278.     : "=r"(retvalue)            /* outputs */        \
  279.     : "g"(n), "r"(_a), "r"(_b), "r"(_c)     /* inputs  */        \
  280.     : "d0", "d1", "d2", "a0", "a1", "a2"    /* clobbered regs */    \
  281.       AND_MEMORY                            \
  282.     );                                \
  283.     retvalue;                            \
  284. })
  285.  
  286. #define trap_1_wwwl(n, a, b, c)                        \
  287. __extension__                                \
  288. ({                                    \
  289.     register long retvalue __asm__("d0");                \
  290.     short _a = (short)(a);                        \
  291.     short  _b = (short)(b);                        \
  292.     long  _c = (long)(c);                        \
  293.                                         \
  294.     __asm__ volatile                        \
  295.     ("\
  296.         movl    %4,sp@-; \
  297.         movw    %3,sp@-; \
  298.         movw    %2,sp@-; \
  299.         movw    %1,sp@-; \
  300.         trap    #1;    \
  301.         lea     sp@(10),sp "                    \
  302.     : "=r"(retvalue)            /* outputs */        \
  303.     : "g"(n), "r"(_a), "r"(_b), "r"(_c)     /* inputs  */        \
  304.     : "d0", "d1", "d2", "a0", "a1", "a2"    /* clobbered regs */    \
  305.       AND_MEMORY                            \
  306.     );                                \
  307.     retvalue;                            \
  308. })
  309.  
  310. #define trap_1_wwl(n, a, b)                        \
  311. __extension__                                \
  312. ({                                    \
  313.     register long retvalue __asm__("d0");                \
  314.     short _a = (short)(a);                        \
  315.     long  _b = (long) (b);                        \
  316.                                         \
  317.     __asm__ volatile                        \
  318.     ("\
  319.         movl    %3,sp@-; \
  320.         movw    %2,sp@-; \
  321.         movw    %1,sp@-; \
  322.         trap    #1;    \
  323.         addqw    #8,sp "                    \
  324.     : "=r"(retvalue)            /* outputs */        \
  325.     : "g"(n), "r"(_a), "r"(_b)        /* inputs  */        \
  326.     : "d0", "d1", "d2", "a0", "a1", "a2"    /* clobbered regs */    \
  327.       AND_MEMORY                            \
  328.     );                                \
  329.     retvalue;                            \
  330. })
  331.  
  332. #if __GNUC__ > 1
  333. #define trap_1_wwllll(n, a, b, c, d, e)                    \
  334. __extension__                                \
  335. ({                                    \
  336.     register long retvalue __asm__("d0");                \
  337.     short _a = (short)(a);                        \
  338.     long  _b = (long) (b);                        \
  339.     long  _c = (long) (c);                        \
  340.     long  _d = (long) (d);                        \
  341.     long  _e = (long) (e);                        \
  342.                                         \
  343.     __asm__ volatile                        \
  344.     ("\
  345.         movl    %6,sp@-; \
  346.         movl    %5,sp@-; \
  347.         movl    %4,sp@-; \
  348.         movl    %3,sp@-; \
  349.         movw    %2,sp@-; \
  350.         movw    %1,sp@-; \
  351.         trap    #1;    \
  352.         lea     sp@(20),sp "                    \
  353.     : "=r"(retvalue)            /* outputs */        \
  354.     : "g"(n), "r"(_a), "r"(_b), "r"(_c), "r"(_d), "r"(_e) /* inputs  */ \
  355.     : "d0", "d1", "d2", "a0", "a1", "a2"    /* clobbered regs */    \
  356.       AND_MEMORY                            \
  357.     );                                \
  358.     retvalue;                            \
  359. })
  360. #else
  361. #define trap_1_wwllll(n, a, b, c, d, e)                    \
  362. ({                                    \
  363.     register long retvalue __asm__("d0");                \
  364.     short _a = (short)(a);            \
  365.     long  _b = (long) (b);            \
  366.     long  _c = (long) (c);            \
  367.     long  _d = (long) (d);            \
  368.     long  _e = (long) (e);            \
  369.                                         \
  370.     __asm__ volatile                        \
  371.     ("\
  372.         movl    %4,sp@-; \
  373.         movl    %3,sp@-; \
  374.         movl    %2,sp@-; \
  375.         movl    %1,sp@-; \
  376.         movw    %0,sp@-    "                    \
  377.     :                          /* outputs */    \
  378.     : "r"(_a), "r"(_b), "r"(_c), "r"(_d), "r"(_e) /* inputs  */    \
  379.     );                                \
  380.                                     \
  381.     __asm__ volatile                        \
  382.     ("\
  383.         movw    %1,sp@-; \
  384.         trap    #1;    \
  385.         lea     sp@(20),sp "                    \
  386.     : "=r"(retvalue)            /* outputs */        \
  387.     : "g"(n)                /* inputs  */        \
  388.     : "d0", "d1", "d2", "a0", "a1", "a2"    /* clobbered regs */    \
  389.     );                                \
  390.     retvalue;                            \
  391. })
  392. #endif
  393.  
  394. #else
  395.  
  396. #ifdef __GNUC__
  397. # ifndef __MSHORT__
  398. #  define __LONG_TRAPS__
  399. # endif
  400. #endif
  401.  
  402. #ifdef __C68__
  403. # define __LONG_TRAPS__
  404. # /* name changes to accommodate c68's trapgen optimizer */
  405. # define trap_1_wwlw    _trap_1_wwlw
  406. # define trap_1_wwww    _trap_1_wwww
  407. # define trap_1_wwl    _trap_1_wwl
  408. # define trap_1_wwwl    _trap_1_wwwl
  409. # define trap_1_wwllll    _trap_1_wwllll
  410. __EXTERN long trap_1_wwlw __PROTO((short, short, long, short));
  411. __EXTERN long trap_1_wwww __PROTO((short, short, short, short));
  412. __EXTERN long trap_1_wwl __PROTO((short, short, long));
  413. __EXTERN long trap_1_wwwl __PROTO((short, short, short, long));
  414. __EXTERN long trap_1_wwllll __PROTO((short, short, long, long, long, long));
  415. #endif /* __C68__ */
  416.  
  417. #ifdef __SOZOBON__
  418. # undef __LONG_TRAPS__    /* just to be safe... */
  419. #endif /* __SOZOBON__ */
  420.  
  421. #ifndef __LONG_TRAPS__
  422. # ifndef trap_1_w
  423. #  define trap_1_w(n)        gemdos(n)
  424. #  define trap_1_wl(n,a)        gemdos(n, (long)(a))
  425. #  define trap_1_wll(n, a, b)    gemdos(n, (long)(a), (long)(b))
  426. #  define trap_1_ww(n,a)        gemdos(n, a)
  427. #  define trap_1_www(n,a,b)    gemdos(n, a, b)
  428. #  define trap_1_wwlll(n,a,b,c,d) gemdos(n, a, (long)(b), (long)(c), (long)(d))
  429. #  define trap_1_wwll(n, a, b, c)    gemdos(n, a, (long)(b), (long)(c))
  430. #  define trap_1_wlw(n, a, b)    gemdos(n, (long)(a), b)
  431. #  define trap_1_wlww(n, a, b, c)    gemdos(n, (long)(a), b, c)
  432. #  define trap_13_w(n)        bios(n)
  433. #  define trap_14_w(n)        xbios(n)
  434. # endif
  435. # define trap_1_wwlw(n,a,b,c)    gemdos(n, a, (long)(b), c)
  436. # define trap_1_wwww(n,a,b,c)    gemdos(n, a, b, c)
  437. # define trap_1_wwl(n, a, b)    gemdos(n, a, (long)(b))
  438. # define trap_1_wwwl(n,a,b,c)    gemdos(n, a, b, (long)(c))
  439. # define trap_1_wwllll(n, a, b, c, d, e) \
  440.         gemdos(n, a, (long)(b), (long)(c), (long)(d), (long)(e))
  441. #endif /* __LONG_TRAPS__ */
  442.  
  443. #endif /* __GNUC_INLINE__ */
  444.  
  445. #define    Syield()                        \
  446.         (int)trap_1_w(0xff)
  447. #define Fpipe(ptr)                        \
  448.         (int)trap_1_wl(0x100, (long)(ptr))
  449. #define Fcntl(f, arg, cmd)                    \
  450.         trap_1_wwlw(0x104, (short)(f), (long)(arg), (short)(cmd))
  451. #define Finstat(f)                        \
  452.         trap_1_ww(0x105, (short)(f))
  453. #define Foutstat(f)                        \
  454.         trap_1_ww(0x106, (short)(f))
  455. #define Fgetchar(f, mode)                    \
  456.         trap_1_www(0x107, (short)(f), (short)(mode))
  457. #define Fputchar(f, ch, mode)                    \
  458.         trap_1_wwlw(0x108, (short)(f), (long)(ch), (short)(mode))
  459.  
  460. #define Pwait()                            \
  461.         trap_1_w(0x109)
  462. #define Pnice(delta)                        \
  463.         (int)trap_1_ww(0x10a, (short)(delta))
  464. #define Pgetpid()                        \
  465.         (int)trap_1_w(0x10b)
  466. #define Pgetppid()                        \
  467.         (int)trap_1_w(0x10c)
  468. #define Pgetpgrp()                        \
  469.         (int)trap_1_w(0x10d)
  470. #define Psetpgrp(pid, grp)                    \
  471.         (int)trap_1_www(0x10e, (short)(pid), (short)(grp))
  472. #define Pgetuid()                        \
  473.         (int)trap_1_w(0x10f)
  474. #define Psetuid(id)                        \
  475.         (int)trap_1_ww(0x110, (short)(id))
  476. #define Pkill(pid, sig)                        \
  477.         (int)trap_1_www(0x111, (short)(pid), (short)(sig))
  478. #define Psignal(sig, handler)                    \
  479.         trap_1_wwl(0x112, (short)(sig), (long)(handler))
  480. #define Pvfork()                        \
  481.         trap_1_w(0x113)
  482. #define Pgetgid()                        \
  483.         (int)trap_1_w(0x114)
  484. #define Psetgid(id)                        \
  485.         (int)trap_1_ww(0x115, (short)(id))
  486. #define Psigblock(mask)                        \
  487.         trap_1_wl(0x116, (unsigned long)(mask))
  488. #define Psigsetmask(mask)                    \
  489.         trap_1_wl(0x117, (unsigned long)(mask))
  490. #define Pusrval(arg)                        \
  491.         trap_1_wl(0x118, (long)(arg))
  492. #define Pdomain(arg)                        \
  493.         (int)trap_1_ww(0x119, (short)(arg))
  494. #define Psigreturn()                        \
  495.         (void)trap_1_w(0x11a)
  496. #define Pfork()                            \
  497.         trap_1_w(0x11b)
  498. #define Pwait3(flag, rusage)                    \
  499.         trap_1_wwl(0x11c, (short)(flag), (long)(rusage))
  500. #define Fselect(time, rfd, wfd, xfd)                \
  501.         (int)trap_1_wwlll(0x11d, (unsigned short)(time), (long)(rfd), \
  502.                 (long)(wfd), (long)(xfd))
  503. #define Prusage(rsp)                        \
  504.         (int)trap_1_wl(0x11e, (long)(rsp))
  505. #define Psetlimit(i, val)                    \
  506.         trap_1_wwl(0x11f, (short)(i), (long)(val))
  507.  
  508. #define Talarm(sec)                        \
  509.         trap_1_wl(0x120, (long)(sec))
  510. #define Pause()                            \
  511.         (void)trap_1_w(0x121)
  512. #define Sysconf(n)                        \
  513.         trap_1_ww(0x122, (short)(n))
  514. #define Psigpending()                        \
  515.         trap_1_w(0x123)
  516. #define Dpathconf(name, which)                    \
  517.         trap_1_wlw(0x124, (long)(name), (short)(which))
  518.  
  519. #define Pmsg(mode, mbox, msg)                    \
  520.         trap_1_wwll(0x125, (short)(mode), (long)(mbox), (long)(msg))
  521. #define Fmidipipe(pid, in, out)                    \
  522.         trap_1_wwww(0x126, (short)(pid), (short)(in),(short)(out))
  523. #define Prenice(pid, delta)                    \
  524.         (int)trap_1_www(0x127, (short)(pid), (short)(delta))
  525. #define Dopendir(name, flag)                    \
  526.         trap_1_wlw(0x128, (long)(name), (short)(flag))
  527. #define Dreaddir(len, handle, buf)                \
  528.         trap_1_wwll(0x129, (short)(len), (long)(handle), (long)(buf))
  529. #define Drewinddir(handle)                    \
  530.         trap_1_wl(0x12a, (long)(handle))
  531. #define Dclosedir(handle)                    \
  532.         trap_1_wl(0x12b, (long)(handle))
  533. #define Fxattr(flag, name, buf)                    \
  534.         trap_1_wwll(0x12c, (short)(flag), (long)(name), (long)(buf))
  535. #define Flink(old, new)                        \
  536.         trap_1_wll(0x12d, (long)(old), (long)(new))
  537. #define Fsymlink(old, new)                    \
  538.         trap_1_wll(0x12e, (long)(old), (long)(new))
  539. #define Freadlink(siz, buf, linknm)                \
  540.         trap_1_wwll(0x12f, (short)(siz), (long)(buf), (long)(linknm))
  541. #define Dcntl(cmd, name, arg)                    \
  542.         trap_1_wwll(0x130, (short)(cmd), (long)(name), (long)(arg))
  543. #define Fchown(name, uid, gid)                    \
  544.         trap_1_wlww(0x131, (long)(name), (short)(uid), (short)(gid))
  545. #define Fchmod(name, mode)                    \
  546.         trap_1_wlw(0x132, (long)(name), (short)(mode))
  547. #define Pumask(mask)                        \
  548.         (int)trap_1_ww(0x133, (short)(mask))
  549. #define Psemaphore(mode, id, tmout)                \
  550.         trap_1_wwll(0x134, (short)(mode), (long)(id), (long)(tmout))
  551. #define Dlock(mode, drive)                    \
  552.         (int)trap_1_www(0x135, (short)(mode), (short)(drive))
  553. #define Psigpause(mask)                        \
  554.         (void)trap_1_wl(0x136, (unsigned long)(mask))
  555. #define Psigaction(sig, act, oact)                    \
  556.         trap_1_wwll(0x137, (short)(sig), (long)(act), (long)(oact))
  557. #define Pgeteuid()                        \
  558.         (int)trap_1_w(0x138)
  559. #define Pgetegid()                        \
  560.         (int)trap_1_w(0x139)
  561. #define Pwaitpid(pid,flag, rusage)                \
  562.         trap_1_wwwl(0x13a, (short)(pid), (short)(flag), (long)(rusage))
  563. #define Dgetcwd(path, drv, size)                \
  564.         trap_1_wlww(0x13b, (long)(path), (short)(drv), (short)(size))
  565. #define Salert(msg)                        \
  566.         trap_1_wl(0x13c, (long)(msg))
  567. /* The following are not yet official... */
  568. #define Tmalarm(ms)                        \
  569.         trap_1_wl(0x13d, (long)(ms))
  570. #define Psigintr(vec, sig)                    \
  571.         trap_1_www(0x13e, (short)(vec), (short)(sig))
  572. #define Suptime(uptime, avenrun)                \
  573.         trap_1_wll(0x13f, (long)(uptime), (long)(avenrun))
  574. #define Dxreaddir(len, handle, buf, xattr, xret)        \
  575.         trap_1_wwllll(0x142, (short)(len), (long)(handle), \
  576.                   (long)(buf), (long)(xattr), (long)(xret))
  577. #define Pseteuid(id)                        \
  578.         (int)trap_1_ww(0x143, (short)(id))
  579. #define Psetegid(id)                        \
  580.         (int)trap_1_ww(0x144, (short)(id))
  581. #define Psetauid(id)                        \
  582.         (int)trap_1_ww(0x145, (short)(id))
  583. #define Pgetauid()                        \
  584.         (int)trap_1_w(0x146)
  585. #define Pgetgroups(gidsetlen, gidset)                \
  586.         trap_1_wwl(0x147, (short)(gidsetlen), (long)(gidset))
  587. #define Psetgroups(gidsetlen, gidset)                \
  588.         trap_1_wwl(0x148, (short)(gidsetlen), (long)(gidset))
  589. #define Tsetitimer(which, interval, value, ointerval, ovalue)    \
  590.         trap_1_wwllll(0x149, (short)(which), (long)(interval), \
  591.                   (long)(value), (long)(ointerval), (long)(ovalue))
  592. #define Scookie(action, yummy)   \
  593.         trap_1_wwl(0x14a, (short)(action), (long)(yummy))
  594. #define Psetreuid(rid, eid)   \
  595.         (int)trap_1_www(0x14e, (short)(rid), (short)(eid))
  596. #define Psetregid(rid, eid)   \
  597.         (int)trap_1_www(0x14f, (short)(rid), (short)(eid))
  598. #define Sync()   \
  599.         trap_1_w(0x150)
  600. #define Shutdown(restart)  \
  601.         trap_1_wl(0x151, (long)(restart))
  602. #define Dreadlabel(path, label, maxlen)  \
  603.         trap_1_wllw(0x152, (long)(path), (long)(label), (short)(maxlen))
  604. #define Dwritelabel(path, label)  \
  605.         trap_1_wll(0x153, (long)(path), (long)(label))
  606.  
  607.  
  608. #endif /* __LATTICE__ */
  609. #endif /* __TURBOC__ */
  610.  
  611. #ifdef __cplusplus
  612. }
  613. #endif
  614.  
  615. #endif /* _MINTBIND_H */
  616.